МІНІСТЕРСТВО ОСВІТИ І НАУКИ, МОЛОДІ ТА СПОРТУ УКРАЇНИ
Національний університет «Львівська політехніка»
ІЕПТ ім. В’ячеслава Чорновола
Кафедра загальної екології та
екоінформаційних систем
ЗВІТ
по лабораторній роботі №3
на тему:
“ Робота з пам’яттю ”
Львів – 2012
Мета – навчитися використовувати системну пам’ять та розміщати в ній дані з файлу.
ТЕОРЕТИЧНІ ПОЛОЖЕННЯ
Пам’ять є основним ресурсом при програмуванні в багатозадачному середовищі. Множина вільних фрагментів пам’яті називається хіп (від англійського слова HEAP). Програміст може виділити для своєї програми блок пам’яті будь-якої довжини, що не перевищує загальний об’єм вільної пам’яті. В Windows пам’ять виділяється в 2 етапи:
спочатку система виділяє фрагмент віртуальної пам’яті, який отримує свій хендл, але не отримує реальної адреси;
потім система розміщує (блокує) цей фрагмент у реальній пам’яті і фрагмент отримує початкову адресу.
Після того, як програміст отримує адресу початку виділеного блоку, він може її використовувати. Комірки з адресами до початку та після кінця блоку використовувати не можна, тому що вони належать іншим програмам або системі.
Після того, як програма використала блок пам’яті, його необхідно розблокувати. Таким чином, він знову стає віртуальним, і при необхідності може бути переміщений системою в інше місце або на диск. Якщо програма довго не розблоковує блок пам’яті, то це негативно відображається на продуктивності операційної системи в цілому. Отже, якщо після розблокування пам’яті її знову заблокувати, адреса початку блоку може бути іншою. Якщо програміст взагалі відмовляється від використання виділеного блоку пам’яті, він повинен звільнити блок, що веде до знищення його хендла. Очевидно, що перед звільненням блоку пам’яті його необхідно розблокувати.
ВИКОНАННЯ РОБОТИ
GetOpenFileName
Код програми
.486
.model flat,STDCALL
extrn CreateFileA:Proc
extrn GlobalAlloc:Proc
extrn GlobalLock:Proc
extrn ReadFile:Proc
extrn GetLastError:Proc
extrn MessageBoxA:Proc
extrn CloseHandle:Proc
extrn GlobalUnlock:Proc
extrn GlobalFree:Proc
extrn ExitProcess:Proc
extrn GetOpenFileNameA:Proc
.data
adress_struct db 256 dup(0)
filter_tab db "Графiчнi файли (*.BMP)",0h,"*.BMP",0
db "Текстовi файли (*.TXT)",0,"*.txt",0
db "Лабораторнi роботи (*.ASM)",0,"*.asm",0
db "Всi типи файлiв (*.*)",0h,"*.*",0,0
dir db "C:\asembler\lab3",0
titl db "Лабораторна робота №3 ",0
title1 db 'Лабораторна робота №3 ',0
openname db 'ReadFile.asm',250 dup(0)
hFile dd 0
hMemory dd 0 ; Хендл блоку пам’яті
pMemory dd 0 ; Адреса блоку пам’яті
SizeRead dd 0
MEMSIZE equ 1000000h ; 16 Mb
Adress_struct:
FSize dd 76 ; довжина цiєї структури;
Howner dd 0 ; вказiвник вiкна-власника або 0;
AppHWnd dd 0 ; вказiвник модуля-власника;
Filters dd offset filter_tab ; вказiвник на перелiк типiв файлiв;
CustFilters dd 0 ; вказiвник на перелiк типiв файлiв якi дозволенi користувачевi;
CstFltSize dd 0 ; довжина буферу на який вказує CustFilters;
CurFilter dd 3 ; iндекс вибраного фiльтру (1,2,3,...) або 0;
CurFileName dd offset openname ; вказiвник на повне iм'я файлу, наприклад, на “С:\dir1\dir2\file.ext”,0;
CurFlNmSize dd 512 ; довжина буферу вказаного в CurFileName;
CurFile dd 0 ; вказiвник на iм'я файлу з розширенням;
CurFlSize dd 0 ; довжина буферу вказаного в CurFile;
InitialDir dd offset dir ; вказiвник на каталог файлу або 0 для даного каталога;
DlgTitle dd offset titl ; вказiвник на назву вiкна;
Flags dd 00h ; тип вiкна, яке вiдкриває файл (може бути 200h);
FileOffset dw 0 ; повертає довжину повного шляху, наприклад=13 якщо користувач ввів рядок “С:\dir1\dir2\file.asm”;
ExtOffset dw 0 ; змiщення вiд початку рядка до розширення (в даному прикладi =18) або 0 якщо розширення немає;
Extension dd 0 ; вказiвник на...